### Managment and Analysis of Physics Dataset – 1 A.A. 2019-20

# Digital Circuits - 2

#### Overview

**G.Collazuol** 

- Recap previous lecture
- Boolean algebra and Logic gates
- Representations of Digital Circuits
- Transistor Gates and Logic Families
- Timing in Digital Circuits
- Digital Circuits properties:
  - → Asynchronous vs Synchronous
  - → Combinational vs Sequential

!!! Lectures time table NFXT WFFK

### Lecture #2 – Recap – MOSFET transistor





What is a MOS transistor?

Analog circuits: amplifier (V to I)

Digital circuits: switch

Y. Tsividis, Operation and Modeling of The MOS Transistor, 2nd edition, McGraw-Hill, 1999.

### Lecture #2 – Recap – MOSFET working regions



LINEAR REGION (Low  $V_{DS}$ ): Electrons are attracted to the  $SiO_2 - Si$  interface. A conductive channel is created between source and drain. We have a Voltage Controlled Resistor (VCR).



SATURATION REGION (High V<sub>DS</sub>): When the drain voltage is high enough the electrons near the drain are insufficiently attracted by the gate, and the channel is pinched off. We have a Voltage Controlled Current Source (VCCS).

## Lecture #2 – Recap – MOSFET working regions

#### SATURATION REGION:

$$V_{DS} > \frac{V_{GS} - V_{T}}{n} = V_{DS\_SAT}$$

$$I_{DS} = \frac{\beta}{2n} (V_{GS} - V_{T})^{2}$$



#### LINEAR REGION:

$$V_{DS} < \frac{V_{GS} - V_{T}}{n} = V_{DS\_SAT}$$

$$I_{DS} = \beta \left( V_{GS} - V_{T} - \frac{nV_{DS}}{2} \right) V_{DS}$$

# Lecture #2 – Recap – MOSFET with a load R<sub>D</sub>



K. R. Laker and W. M. C. Sansen, Design of Analog Integrated Circuits and Systems, McGraw-Hill, 1994.

#### Lecture #2 – Recap – transfer function and logic levels



Fundamental property #1 → Noise margin

#### Lecture #2 – Recap – transfer function and logic levels





Vin input level perturbation due to interefecence from other regiosn of the digital circuit (via parasitic capacitive coupling)

#### Fundamental property #1 → Noise margin

### Lecture #2 – Recap – MOSFET types



#### Lecture #2 – Recap – CMOS tecnology



### Lecture #2 – Recap – why CMOS?



Negligible current is drawn from Power Supplies ...

### Lecture #2 – Recap – why CMOS?

Simulation of a chain of two inverters in a 0.25 µm CMOS technology



Negligible current is drawn from Power Supplies ... except during transitions (very fast → current spikes)

### Lecture #2 – Recap – why CMOS?

Simulation of a chain of two inverters in a 0.25 µm CMOS technology



- (1) very fast transition but anyway some delay is there
- (2) low\_Z output and high\_Z input = only 2 levels involved

# Lecture #2 – Logic levels propagation: Fundamental property #2 → Fanout

Digital ports must allow fanout (multiple copies of output signals) !

→ this is one of tha main reasons for Digital Electronics works with voltage signals (instead of current)

- → input: high Z
- → output: low Z



Note: high Z output is used for circuit control (see tristate)

#### Logic Levels

Analog signals → continuous values within a certain range...

... but when signals take on only discrete values (integers) → digital signals

Electronic devices with two well-defined states arise much more naturally than devices with ten states: binary representation

#### Digital circuits mandatory for

- logic and arithmetic functions in computers
- transmission of the digitized signals over noisy channels is often perfect



The big advantage of digital electronics is that there are relatively wide margins in the definition of logic levels. Even in the presence of noise that dynamically alters the signal value the digital information does not change.

# Boolean Algebra and Logic Gates

## **Binary information**



#### Integer representations

#### Binary-to-Decimal Conversion

#### Decimal-to-Binary Conversion

#### 109 to binary

109/2 = 54 w/ remainder 1 (LSB) 54/2 = 27 w/ remainder 0 27/2 = 13 w/ remainder 1 13/2 = 6 w/ remainder 1 6/2 = 3 w/ remainder 0 3/2 = 1 w/ remainder 1 1/2 = 0 w/remainder 1 (MSB)

> Answer: 1101101 8-bit answer: 01101101

Take decimal number and keep dividing by 2, while keeping the remainders. The first remainder becomes the LSB, while the last one becomes the MSB.

#### 10100100 to decimal



Expand the binary number as shown and add up the terms. The result will be in decimal form.

Answer: 164<sub>10</sub>

| Octal to Binary            | Binary to Octal                   |
|----------------------------|-----------------------------------|
| 537 <sub>8</sub> to binary | 111 001 100 <sub>2</sub> to octal |
| 5 3 7                      | 111 001 100                       |
| Answer: 101011111,         | Answer: 714                       |

A 3-digit binary number is replaced for each octal digit, and vice versa. The 3-digit terms are then grouped (or octal terms are grouped).

| Hex to Binary                       | Binary to Hex                  |
|-------------------------------------|--------------------------------|
| 3E9 <sub>16</sub> to binary         | 1001 1111 1010 0111 2 to octal |
| 3 E 9                               | 1001 1111 1010 0111            |
| 001111101001                        | 9 F A 7                        |
| Answer: 0011 1110 1001 <sub>2</sub> | Answer: 9FA7 <sub>16</sub>     |

A 4-digit binary number is replaced for each hex digit, and vice versa. The 4-digit terms are then grouped (or hex terms are grouped).

### Negative integers → 2's complement

In 2's complement representation a negative number is represented by a binary which results in zero when added to its corresponding positive

#### Decimal to 2's complement

+ 4<sub>10</sub> to 2's complement

true binary =  $0010\ 1001$ 2's comp =  $0010\ 1001$ 

-41<sub>10</sub> to 2's complement

true binary = 0010 1001 1's comp = 1101 0110 Add 1 = +1 2's comp = 1101 0111

In 2's complement representation the procedures for adding and subtracting positive and negative numbers are the same

| DECIMAL   | SIGN-MAGNITUDE | 2'S<br>COMPLEMENT |
|-----------|----------------|-------------------|
| +7        | 0000 0111      | 0000 0111         |
| +6        | 0000 0110      | 0000 0110         |
| +5        | 0000 0101      | 0000 0101         |
| +4        | 0000 0100      | 0000 0100         |
| +3        | 0000 0011      | 0000 0011         |
| +2        | 0000 0010      | 0000 0010         |
| +1        | 0000 0001      | 0000 0001         |
| 0         | 0000 0000      | 0000 0000         |
| -1        | 1000 0001      | 1111 1111         |
| -2        | 1000 0010      | 1111 1110         |
| -3        | 1000 0011      | 1111 1101         |
| -4        | 1000 0100      | 1111 1100         |
| -5        | 1000 0101      | 1111 1011         |
| -6        | 1000 0110      | 1111 1010         |
| <b>-7</b> | 1000 0111      | 1111 1001         |
| -8        | 1000 1000      | 1111 1000         |

### Binary Arithmetic: addition / subtraction

#### **Adding**

#### **Subtracting**

the long way

2's complement way

### Binary Arithmetic: multiplication / division (by 2)

#### Multiplicating

Multiplication by 2 of a nonnegative integer less than  $2^{N-2}$  is obtained by shifting all bits one position to the left (throwing away the MSB) and writing a 0 into the least significant bit

eg 3 · 2 is left shift 
$$0011_2 = 0110_2 = 6_{10}$$
  
-3 · 2 is  $1101_2 = 1010_2 = -6_{10}$ 

The overflow can be detected because the result of the shift is negative eg  $7 \cdot 2$  is  $0111_2$  results in  $1110_2 = -2_{10}$ !!! overflow  $-5 \cdot 2$  is  $1011_2$  results in  $0110_2 = 6_{10}$ 

#### Dividing

Division by 2 of a non-negative integer is carried out by throwing away the least significant bit (or perhaps storing it elsewhere as the remainder),

shifting the remaining bits one position to the right and writing a 0 into the most significant bit

eg shifting  $0111_2 = 7_{10}$  to the right, for example, results in  $0011_2 = 3_{10}$ 

Note: Shifts and Sums → easily carried by digital circuits ...

#### Binary Algebra operations and variables

OR ..... 
$$0+0=0$$
  $0+1=1$   $1+0=1$   $1+1=1$  ..... union AND ....  $0\cdot 0=0$   $0\cdot 1=0$   $1\cdot 0=0$   $1\cdot 1=1$  .... intersection complement  $\overline{0}=1$   $\overline{1}=0$ 

Boolean algebra → variables

$$\overline{\overline{A}} = A$$
  $A + A = A$   $A + 0 = A$   $A + 1 = 1$   $A + \overline{A} = 1$   $A \cdot A = A$   $A \cdot 0 = 0$   $A \cdot 1 = A$   $A \cdot \overline{A} = 0$ 

 addition and multiplication are commutative and associative:

$$A+B=B+A$$
  $A+(B+C)=(A+B)+C$   
 $A \cdot B=B \cdot A$   $A \cdot (B \cdot C)=(A \cdot B) \cdot C$ 

multiplication is distributive over addition:

$$A \cdot (B+C) = (A \cdot B) + (A \cdot C)$$
$$A+(B \cdot C) = (A+B) \cdot (A+C)$$

De Morgan theorems

$$\overline{A+B} = \overline{A}\overline{B}$$
  $\overline{AB} = \overline{A} + \overline{B}$ 

Central theorems in Digital electronics

Note:  $\rightarrow$  AND can be implemented by using just OR e NOT → OR can be implemented by using just AND e NOT

### Binary Algebra logical functions and conditions

If A, B, and C are logical variables

$$\Phi = A\overline{C} + BC + AB$$
 is a logical function

A logical function can be described by a truth table that lists all possible arrays of values of the logical variables together with the corresponding values of the function



#### Logical conditions

Can detect the condition [A>B] by interpreting A and B as logical variables, executing the logical function AB and demanding that the result be 1

If we continue this process, we obtain the following list of correspondences between bit comparisons and logical functions:

$$[A>B] \leftrightarrow A \cdot \overline{B} \qquad [A \le B] \leftrightarrow \overline{A} + B$$

$$[A

$$[A=B] \leftrightarrow \overline{A \oplus B} \qquad [A \ne B] \leftrightarrow A \oplus B$$
<sub>22</sub>$$

#### **Logic Gates**







XOR and XNOR are used very often



#### Note: bubble pushing

A shortcut method for forming equivalent logic circuits, based on De Morgan's theorem, is to use what's called *bubble pushing*.

Bubble pushing involves the following tricks:

- Change an AND gate to an OR gate or change an OR gate to an AND gate.
- Add inversion bubbles to the inputs and outputs where there were none, while removing the
  original bubbles.

#### Universal capability of NAND and NOR gates

NAND and NOR gates are referred to as universal gates because each one can be combined with itself to form all other possible logic gates

| Logic gate  | NAND equivalent circuit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NOR equivalent circuit                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| NOT ————    | $A \longrightarrow \overline{AA} = \overline{A}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $A - \overbrace{\hspace{1cm}}^{\overline{A+A}} = \overline{A}$                                            |
| AND<br>———  | $ \begin{array}{c} A \\ B \end{array} $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $A \longrightarrow \overline{A+A} = \overline{A}$ $B \longrightarrow \overline{A+B} = \overline{AB} = AB$ |
| NAND<br>——— | =>-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | $A \longrightarrow AB$ $B \longrightarrow AB$                                                             |
| OR —        | $A \longrightarrow \overline{A}$ $B \longrightarrow \overline{B}$ $A \longrightarrow \overline{A}\overline{B} = A + B$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | $ \begin{array}{c} A + B \\ B \\ \end{array} $ $ \overline{(A+B)} + \overline{(A+B)} = A + B $            |
| NOR ——      | $A \longrightarrow \overline{A} \overline{B} = A + B$ $B \longrightarrow \overline{B}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ⇒>-                                                                                                       |
| XOR ——      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                           |
| XNOR —      | A POPULATION OF THE POPULATION |                                                                                                           |

#### Logic functions with n-inputs to m-outputs

ie n single bit independent variables and m-bits dependent functions

We have seen n-to-1 bits logic functions ... but of course n-to-m bits must be consedered

→ need to introduce just 2 new operators in addition



Note: indeed EXCHANGE is enough (for you can short-circuit inputs to get FANOUT)

#### Digital circuits =

hardware implementation of logical and arithmetical functions

#### Representations of Digital Circuits

Schematic diagram & gates

Boolean equation

out6 = /in3\*/in2\*/in1 + in3\*in2\*/in1\*/in0 + /in3\*in2\*in1\*in0





Truth table

| out[6:0] |
|----------|
| 1000000  |
| 1111001  |
| 0100100  |
| 0110000  |
| 0011001  |
| 0010010  |
| 0000010  |
| 1111000  |
| 0000000  |
| 0010000  |
|          |

Hardware Description Language (HDL)

```
3-to-1 MUX
module mux32three(10,11,12,sel,out);
input [31:0] 10,11,12;
input [1:0] sel;
output [31:0] out;
reg [31:0] out;
always @ (10 or 11 or 12 or sel)
begin
  case (sel)
    2'b00: out = 10:
    2'b01: out = 11:
    2'b10: out = 12;
    default: out = 32'bx;
  endcase
end
endmodule
```

### **Basic Digital Building Blocks**



#### **Basic Digital Building Blocks**

- 1. Primitive gates We have the basic AND, OR, NAND, NOR, XOR and XNOR gates.
- 2. Multiplexers MUXs These are really useful component. Shown here is a 2-to-1 MUX with two data inputs and one select input. The output is one or the other depending on the select input (sel). We often put a number of these together to provide multiplexing function to a mult-bit data word (as shown here with two 3-bit numbers).
- **3. Arithmetic circuits** Commonly found are adders and multipliers. Subtractor can be built from an adder if we use 2's complement representation of signed integers.
- 4. Encoders/Decoders These two are related. Encoding is a logic module that reduces (encodes) a large number of bits and produces fewer output bits. Decoders are the opposite. Shown here is a 7-segment display decoder, where 4 input bits are decoded into 7 logic signals to drive the seven segments of the display. The encoder here is known as a priority encoder. It produces a 3-bit output showing where the first '1' is encounters from the most-significant bit D7 to the least significant bit D0.
- 5. Flipflops and Registers These are the building blocks for all sequential circuits. As will be seen later, we really only use one type of flipflop the D-FF.

These are all important components that all digital circuit designers need to be familiar with. However, nowadays, we rarely design large digital systems at such low levels. Instead we generally try to express these building blocks in a more abstract manner in a hardware description language (as we will see in later lectures).

In addition to these basic blocks, we also have memory devices and microprocessors.

# How logical and arithmetical functions are implemented in digital circuits?

### Transistor Gates and Logic Families



#### Transistor Gates and Logic Families

Most logic circuits are built using standardized Integrated Circuits (IC) from one of the logic families

Basic gates discussed here:

- TTL family developed by Texas Instruments
- ECL family developed by Motorola Inc.
- CMOS family developed by RCA

#### Requirements on voltage levels:

- 1) voltage levels output → input compatibility
- 2) large fanout, ie can drive many inputs with minimal change in output levels

We'll see that digital circuits have delays!

On the negative side, delays result in finite processing times and therefore set a limit on speed ... ... but on the positive side, delays are essential for the existence of flip-flops (ie memory!) and of state machines (ie "processors"!)

#### TTL

- Prior to (C) MOS logic, digital logic systems were built using Small Scale Integration (SSI) and MediumScale Integration (MSI) integrated circuits.
- These integrated circuits appeared in the mid 70's and were extremely popular for about 20 years (but still in use), eventually supplanted by programmable logic such as FPGA.







A. Marchioro / CERN

#### TTL

- Manufacturers designed a family of SSI/MSI ICs that went by the name of TTL (Transistor-Transistor-Logic) logic. Such ICs used bipolar transistors.
- They used a single 5V supply
- Cascading chips required no passive component
- Power dissipation was OK (for the time)
- Chips were robust and reliable
- Cost/chip was reasonably low
- System speed achievable was >10
   MHz (if properly designed)

 Several families (almost always compatible with one another) existed:

74xx base series

74LSxx low power,

74Sxx high speed

74Fxx very high speed

74ACTxx CMOS

... many many others

 "xx" is a two or three digit number identifying a specific function, e.g. 00 is a quadruple 2-input NAND gate

# 7404 circuit data sheet

 Dependable Tesse Instruments Quality and Reliability

#### description/ordering information

These devices contain six independent inverters.



Packaging (physical) representation



Peace lie sware that an important notice concerning analogicity, standard manachy, and use in critical applications of Taxas instruments commonductor products and disclaiment thereto appears at the end of this class sheet.

PACINGTON DATA Internation is supres as all patriories data front parties in appointment purple famour? Some improvement paging agreem, franchisto processing from an improvement in the



Cooperate C-2004, Name Indicatoring Processing

SN5404, SN54LS04, SN54S04, SN7404, SN74LS04, SN74S04 HEX INVERTERS

SOURCES - DECEMBER 1860 - REVISED JANUARY TO

| TA                        | PAC                | KAGE!                             | ORDERWILE<br>PART NUMBER | TOP-SIDE<br>MARKING |
|---------------------------|--------------------|-----------------------------------|--------------------------|---------------------|
|                           |                    | Tube                              | 58014049                 | SHIPMONE            |
|                           | POP-N              | Total                             | 35074,5045               | 59034,5000          |
|                           |                    | Tube                              | SNP4504H                 | 3NM304N             |
|                           |                    | Tube                              | SMP4040                  | 7404                |
|                           | 183                | Tape and red                      | 38040409                 |                     |
|                           | 900 - D            | Tube                              | 3MP4L3040                | 1.504               |
|                           |                    | Tape and real                     | 5804,59400               |                     |
|                           |                    | Tube                              | SMINESONES               |                     |
|                           |                    | Tage and red                      | SMINSOHOR                | 804                 |
|                           |                    | Tape and real                     | 55074049571              | 5907404             |
|                           | 907 - 195          | Tape and red                      | SMP4LSMSSS               | 791,004             |
|                           |                    | Tape and reel                     | SMINGOMER                | 74504               |
|                           | 880P - DB          | Tape and real                     | 5NP4J504069              | 1.004               |
|                           |                    | Tube                              | SNAMEL                   | BNHOLI              |
|                           |                    | Tube                              | 0NUS4043                 | SPLISHOW            |
|                           |                    | Total                             | 356-4-304J               | 59994L506U          |
|                           | COP - 1            | Tolor                             | (Marcian)                | INMINU              |
|                           | 100                | Total                             | 58054,5047               | 594,644,5047        |
| PO to 19870               | 1 3                | Tuber                             | SNUBHIDAL                | TOTAL STREET        |
|                           |                    | Tube                              | 16UDHON9                 | SPLINKOWY           |
|                           | DEP - M            | Total                             | 5N/54,504VI              | 594,646,506W        |
|                           |                    | Tube                              | SAUD-ESONY               | SPANNING            |
|                           |                    | Total                             | \$8454.554FE             | SNUSAUSONING        |
|                           |                    |                                   |                          | IDATE.              |
| achage do<br>to available | and community      | PUNCTIO                           |                          |                     |
|                           | pril comiteripa    | PUNCTIO<br>(section)              | OUTPUT                   |                     |
|                           | grill constanting  | PUNCTIO<br>(MICH III<br>MPUT<br>A | OUTPUT<br>Y              |                     |
|                           | grill constitution | PUNCTIO<br>(section)              | OUTPUT                   |                     |



----

# 7404 circuit data sheet (2)







### TTL: How does it work?



### TTL: How does it work?

• 
$$A = 0 V$$
  
-  $V_{B,T1} = 0 V$   
-  $T1 \text{ on}$   
-  $V_{C,T1} = 0.2 V$   
-  $V_{B,T2} = 0.2 V$   
-  $T2 \text{ off}$   
-  $V_{B,T3} = 0 V$   
-  $T3 \text{ off}$   
-  $T4 \text{ on}$   
-  $V_{B,T4} = 5 V$   
-  $V_{E,T4} = 5 - 0.7 = 4.3 V$   
-  $Y = 4.3 V$ 



## Low Power, Shottky TTL - LS-TTL → NAND gate

The basic circuit of the LS-TTL family is the NAND gate

Transistors have a Schottky diode from base to collector and thus do not saturate (Q4 is an exception because it is kept out of saturation by the Schottky diode in Q3)



Assume  $V2 = 5V \rightarrow D2$  is reverse biased and can therefore be ignored

If V1=0  $\rightarrow$  VB1  $\sim$  300mV, and Q1 and Q2 are both cut off Note: D1 contends  $V_{drop}$  with BE junctions of Q1 and Q2 (2 x  $V_{drop}$ ) on node A  $\rightarrow$  Darlington Q3/Q4 is on, as at least sees the  $r_0$  load of Q2 If the output load current is within the limits prescribed by family rules (usually 400  $\mu$ A) the output voltage VO is 5V-1.4V  $\sim$  3.6V (Vdrop of Darlington follower Q3|Q4 is 1.4V)

VO remains at this value until V1 is raised to about 1V (threshold voltage) at which point Q1 and Q2 start to turn on and VO starts to drop because the base of Q3 is pulled down by Q1

### Low Power, Shottky TTL - LS-TTL → NAND gate

If V1 > 2V<sub>drop</sub> ~ 1.4V → D1 is cut off and Q1 and Q2 are fully on (if D1 were on → V<sub>node A</sub> = 3V<sub>drop</sub> → Q1 and Q2 on → in conflict on node A) The base currents in Q1 and Q2 are much more than is required for saturation → VCE1 and VCE2 are clamped at about 400 mV by their B-C Schottky diodes → VB3-VE4 is thus about one diode drop, and Q3 and Q4 are therefore both cut off



#### Following family rules we define

- LOW as any voltage under 0.8 V
- HIGH as any voltage above 2.4 V
- → LOW input will give a HIGH output, and vice versa
  If V1 and V2 are both allowed to take on LOW or HIGH values
- → VO will be LOW only if V1 and V2 are both HIGH, → we have a NAND gate

Note: A HIGH input to an LS-TTL gate sees a reverse-biased diode

→ the fanout in the HIGH state is large

According to family rules, a LOW input to an LS-TTL gate sinks 0.4mA in the worst case, and a LOW output must be able to sink 4mA

→ the fanout in the LOW state is thus also large, about 10

# 7400 circuit data sheet (4)

#### SN5404, SN54LS04, SN54804, SN7404, SNT4LS04, SNT4S04 HEX INVERTERS

#### recommended aperating conditions (see Note 3)

|       |                                |                     | 890000 |     | 98/14/904 |      |      | UNIT |
|-------|--------------------------------|---------------------|--------|-----|-----------|------|------|------|
|       |                                | MIN NOW MAD MIN NOW |        | 900 | 880       |      |      |      |
| Non   | Supply votage                  | 4.5                 | - 5    | 1.5 | 4.7%      | - 5  | 5.85 | 1.37 |
| Sec.  | High-level Input willage       | 1                   |        |     | - 2       |      |      | W    |
| No    | Low-level input voltage        |                     |        | 6.8 |           |      | -0.8 |      |
| los . | High-head sulput surrent       |                     |        | 11  |           |      | -4   | 100  |
| 104   | Low-level colput surrent       | 1.00                |        | .00 |           |      | 30   | 198  |
| 5     | Operating free-air temperature | -88                 |        | 125 | - 9       | - 50 | . 19 | - 40 |

MOTES. All unusual impulse of the device must be feet at tigg or SNO to resour proper sever operation. Helde to the Thappicalism report INDICATORS OF STORM OF PRINCIPLE CHICAL PROJECT INVALIDATION SCHOOL SCHOOL

#### electrical characteristics over recommended operating free-air temperature range (unless

|                    | TEST CONSTITUTE!    |              | Deletion     |      |       | 8674804 |       |       |      |         |
|--------------------|---------------------|--------------|--------------|------|-------|---------|-------|-------|------|---------|
| PARAMETER          |                     |              | 5604         | TYPE | 1000  | Min     | Tree! | 55436 | 1000 |         |
| Yes                | Noon - Milks        | \$10 - 18 40 | 20 mm        |      |       | -4.8    |       |       | 1-18 | .7      |
| You                | Nach - Milk         | Vg. + 0.8 S. | lose and the | 2.5  | 3.4   |         | 2.7   | 356   |      | . 9     |
| 701                | NGC - MN            | Var-div.     | 100 mA       |      |       | 0.5     |       |       | 8.5  | Y       |
| 1                  | Name of Street,     | Visiter      |              |      |       | . 1     |       |       | - 1  | mil     |
| The contract of    | Magin - MAC.        | Visit Fit    |              |      |       | 50      |       |       | 107  | 165     |
| 1.                 | Name and Associated | No. Oak      |              | 100  |       | -3.     | 5     |       | 1.3  | mak     |
| TO 6 <sup>th</sup> | NOOCH MINOR         | 13000000     |              | -40  | - 100 | -199    | -40   | 100   | -198 | , light |
| PDCM.              | Nac - Max.          | No. of the   |              |      | 19    | 260     |       | 100   | 24   | mil     |
| Pods.              | Magnin MAX.         | No. 650      |              |      | 20    | - 66    | -     | 30    | 194  | 10.0    |

For conditions shown as REH or MAX, use the appropriate value specified under recommended operating conditions.

If all typical values are at V(g) = 5 × T<sub>A</sub> = (5°C).
If the important one copput should be shorted at a time, and the duration of the short-direct should not exceed one second.

#### switching characteristics, V<sub>OC</sub> = 5 K, T<sub>A</sub> = 25°C (see Figure 1)

| PARAMETER: | FROM     | 10          | TREE CONDITIONS            | \$16.4584<br>BHT1884 | user  |
|------------|----------|-------------|----------------------------|----------------------|-------|
|            | (market) | (000 17-01) |                            | THE TYP MAX          |       |
| Thus       |          | 100         | A - 880 A - 15 of          | 9 45                 | - 100 |
| 79%        | 1.0      | 3.0         | 10, - 1000 to 10, - 10 (or | 3 8                  | - 100 |
| THE        | - 4      |             | 5 - 200 0 - 10-2           | 48                   |       |
| Tital      |          |             | of country of contra-      | - E                  | - 100 |

TEXAS INSTRUMENTS

SN5464, SN54LSB4, SN54SB4. SN7464, SN74LS64, SN74564 HEX INVERTERS



- Parameters 1 is to an output of the restriction and that the collect is legal, we can extract where displaced by the collect control.

  51 and 65 are recently in the record of the recent control on the first collect is legal, ended by the collect control.

  51 and 65 are recent from the recent from the recent first collection region. 50 is crossed and 65 is open for region.

  51 and 65 are recent from the recent from the recent first collection region. 50 is not on the recent from the recent first recent from the recent from the recent first recent from the recent from the recent first recent from the recent from the rec
- 1. The sulputs are resource one at artims, with one input transition per measurement.

Figure 1. Load Circuits and Voltage Waveforms.



# **ECL Logic**

- A further logic family was developed to achieve even higher speed that TTL.
  - MECLI,
  - MECLII,
  - MECLIII
  - MECL10000
- Used -1.2 and -5.2 V
- Considerable more power hungry (hotter) than TTL
- Expensive
- Temperature sensitive
- Less complex functions than TTL

- System speed achievable > 100 MHz (with very careful board design)
- Requires transmission lines for signal propagation
- Non-interchangeable chips between families



# ECL gate example





### **Emitter Coupled Pair**

Misura di differenze di tensione e` problema fondamentale (vedere Op.Amp.)

→ discutiamo stadio di ingresso molto utilizzato: emitter coupled pair che si puo`
vedere come un base comune pilotato da un emitter follower...



Supponiamo  $R_L < r_0$  e consideriamo la differenza di tensione tra i due ingressi  $V = V_1 - V_2$  si vede che

Ignorando le piccole correnti di base, la somma delle correnti di collettore e` corrente si bias I=I<sub>1</sub>+I<sub>2</sub>

Gia` con una differenza di tensione di 125mV (5V<sub>T</sub>) si ha il 99% della corrente in un transistor, l'altro e`cut-off 

→ abbiamo un interruttore di corrente (circuiti digitali)

→ abbiamo un interruttore di corrente (circuiti digitali) ... meccanismo ad altalena (basculante) ...

$$V = V_{BE1} - V_{BE2} = V_T \ln \frac{I_1}{I_2}$$

$$I_{1,2} = \frac{I}{2} \left( 1 \pm \tanh \frac{V}{V_T} \right)$$

### ECL family → NOR gate

The Emitter-Coupled Logic (ECL) family has NOR as basic gate circuit



For a moment assume that the bases of Q1 and Q2 are tied together. The circuit can then be described as a differential amplifier whose single-ended collector output voltage is buffered by an emitter follower

Assuming that VBE = 0.8 V in all transistors when they are conducting, the output voltage is -0.8 V when Q1|Q2 is cut off, and -1.6 V when Q3 is cut off and all the current in the 8 mA current source goes through Q1|Q2

With a bias of -1.2 V at the base of Q3, the current switches between Q1|Q2 and Q3 when the base voltage on Q1|Q2 switches between levels that are about 120 mV above and below -1.2 V (threshold)

#### If we define

- HIGH as a voltage above -1.0 V and
- LOW as a voltage below -1.4 V,

a LOW input at the base of Q1|Q2 will give a HIGH output at C, and vice versa

### ECL family → NOR gate

The Emitter-Coupled Logic (ECL) family has NOR as basic gate circuit



If we now untie the bases of Q1 and Q2→ HIGH at either A or B will make C LOW → we are dealing with an ECL NOR gate.

In an actual integrated version the logic levels are somewhat different, (-0.9 V and -1.8 V) but the circuit structure is essentially the same

#### Note:

- 1) ECL circuits can operate at high frequencies: 100MHz is standard and 500MHz is possible
- 2) ECL circuits are well suited for driving transmission lines, which are almost mandatory at such frequencies

### CMOS gates

- Compact (shared diffusion regions)
- Very low static power dissipation
- High noise margin (nearly ideal inverter voltage transfer characteristic)
- Very well modeled and characterized
- Mechanically robust
- Lends itself very well to high integration levels



## CMOS gates

- With development of ICs the MOSFET took the main role in electronics
- We are already producing 10<sup>18</sup> transistors per year enough to supply every ant on the planet with ten transistors.
- Twenty years from now, if the trend continues, there will be more transistors than there will be cells in the total number of human bodies on Earth

  CMOS IC

First IC - Kilby



First microprocessor







Modern intel processor



### NOT gate: PMOS and NMOS inverters



## NOT gate: CMOS inverter



### CMOS family → Inverter

- Complementary enhancement MOSFETs involved
- Assume for simplicity identical characteristics and threshold voltage  $V_{TH}$  = 1 V



If  $VI = 0 \rightarrow Q2$  is cut off and, assuming that VDD = 5 V

- $\rightarrow$  Q1 is well above threshold  $\rightarrow$  acts like a resistor of order 1 k $\Omega$
- → output voltage V0 = VDD and V0 remains at this value as long as VI = 1 V

Similarly if VI is within 1V of VDD  $\rightarrow$  Q1 is cut off and Q2 is on, and V0 = 0

If VI = VDD/2, Q1 and Q2 have the same drain current, and V0 ~ VDD/2 (ideally) By superposition, the small-signal gain at this point is  $2(g_m r_0/2) \sim 100$ 

→ V0 changes rapidly as a function of V1 (see voltage transfer characteristic)

#### At room T, taking

- LOW to be any voltage below 1/3 VDD and
- HIGH to be any voltage above 1/3 VDD

is sufficient to guarantee that a LOW input gives a HIGH output, and vice versa

### CMOS family → NAND and NOR gates



The output of the NAND gate will be LOW only if both p-channel transistors are off and both n-channel transistors are on → this requires that both inputs be HIGH

The output of the NOR gate will be HIGH only if both p-channel transistors are on and both n-channel transistors are off

→ this requires that both inputs be LOW

Note: great advantage of CMOS gates: they draw negligible current from the power supply when they are in a quiescent state ...

... this advantage is lost if they change state at a high rate: for output transitions  $0 \rightarrow V_{DD}$  the current that charges the load capacitance  $C_L$  is provided by the power supply. For output transitions  $V_{DD} \rightarrow 0$ ,  $C_L$  discharges to ground. If this happens at a frequency f, the power supply must provide a current f x  $C_L$  x  $V_{DD}$ 

For f=10MHz,  $C_L$ =10pF, and  $V_{DD}$ =5V, the current is 0.5mA (... far from negligible)

### CMOS family → NAND and NOR gates





The output of the NAND gate will be LOW only if both p-channel transistors are off and both n-channel transistors are on → this requires that both inputs be HIGH

The output of the NOR gate will be HIGH only if both p-channel transistors are on and both n-channel transistors are off

→ this requires that both inputs be LOW

#### Note:

- input currents in CMOS circuits are the gate currents of few MOSFETs and thus extremely small
- In contrast, a CMOS circuit output can tolerate a load current of order 1mA
- → fanout capability is very large

#### Note:

each gate, however, has an input capacitance,

→ driving too many gates can result in an unacceptably slow response

## NAND and NOR gates (CMOS)





Note: NAND (and similarly NOR) allow to build any other type of gate

## Deciphering static gates structure





Example... inverter

### Deciphering static gates structure



# More complex gate

$$F = (A * B) + (C * D)$$



Pulldown network

## More complex gate (2)

The P network is constructed from the complement:

$$F' = (\overline{A} + \overline{B}) * (\overline{C} + \overline{D})$$





## **EX-NOR**

| A | В | Υ |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |



### **CMOS** Buffer



→ allows delays in logic level propagation

### **CMOS Buffer Tristate**



| En | Α | Υ |
|----|---|---|
| 0  | 0 | ? |
| 0  | 1 | ? |
| 1  | 0 | 1 |
| 1  | 1 | 0 |

→ allows control of logic level propagation

... 3rd type of output state: "disconnected" or "High Z"

### **Transmission Gate**



| In | A | Υ |
|----|---|---|
| 0  | 0 | ? |
| 1  | 0 | ? |
| 0  | 1 | 0 |
| 1  | 1 | 1 |



### **Pass Transistor**

- complementary transistors in parallel
- controlled by complementary voltages
   VG to nFET
   VDD-VG to pFET
   (both transistors ON or both OFF)

→ voltage controlled switch

### the CMOS Buffer Tristate





→ allows control of logic level propagation

... 3rd type of output state: "disconnected" or "High Z"

## Multiplexer with gates



| Sel | Α | В | Υ |
|-----|---|---|---|
| 0   | 0 | X | 0 |
| 0   | 1 | X | 1 |
| 1   | X | 0 | 0 |
| 1   | x | 1 | 1 |



# MUX 2-inputs





## Timing in Digital Circuits

## Logic levels propagation vs Time

### → Digital waveforms



The bits possibly change value at the clock rising or falling edge. For example, the sequence of bits 100101101 would give rise to the above digital waveform.

The clock of digital processors determines the speed of mathematical operations; algorithms employ a given number of clock cycles making the processing speed equal to the clock divided by that number.

Well... life with Digital Circuits is more complicated...

### **Delays**

Digital circuits have delays! In addition to interconnections, all real electronic circuits introduces a delay with respect to input transitions with given rise and fall times. The delay caused by a logic cell is named propagation delay (typically it increases with chip temperature and supply voltage)

On the negative side, delays result in finite processing times and therefore set a limit on speed ...

... but on the positive side, delays are essential for the existence of **Sequential Logic** circuits (flip-flops → memories and state machines → processors)



The output should changes at the rising edge of the clock and remains unchanged for the entire clock period.

In real cases, switching from "1" to "0" or vice versa is not instantaneous but occurs with some delay because of the finite speed of electronic circuits that make the rising and falling times are not zero.

### Interconnections → delays

The trace on a PCB or the interconnection of integrated circuits is a metal deposited onto an insulating material.



### Transistors Delays and Transition times



The step response has a **delay** and then a **transition** that can be described in terms of a rise time or a fall time



The transistors that define the dynamic response in logic gates are essentially in the common-emitter or common-source configuration: they switch back and forth between an off-state and an on-state (see figure)

The step response of logic gates is thus also characterized by delays and transition times. Transition times are important because they set conditions on the layout of digital circuits: for example, that ECL circuits must be interconnected with transmission lines in most cases

### Gate delay

Assuming that questions of layout have been properly addressed, we need not consider delay and transition times separately: the only time we really need to know is the time it takes for a transition at the input of a gate to become well reflected at the output so that it can have an effect on other gates (in case the conditions at the input are such that the output will change state)

This overall time or gate delay is equal to real delay + a fraction of transition time

In the logic families we have described, the gate delay depends on the type of gate, but it does not depend much on the direction of the transition if the capacitive load on a gate is light

The gate delays of the basic gates are

- about 2 ns in the ECL family
- 10 ns in the LS-TTL family
- anywhere from 1 to 100 ns in the CMOS family

### Gate delay - example

#### Basic model

- gate delays are independent of the direction of the transition.
  - → describe the dynamics of logic gates in terms of a single time, the gate delay t
- take transition times to be zero so that we can locate events conveniently



If we consider only the static behavior of the circuit → B=0 always...

...but if we take into account the delays in the inverter and in the AND gate

→ B exhibits a pulse of width t when A goes from 0 to 1, and the leading edge of the pulse is delayed by t with respect to the leading edge of A

Note: gate delays can be profitably used to generate short pulses, but they can also result in unintended pulses that make other circuits malfunction or, more generally, in a race condition in which a signal that is meant to block a gate before other inputs change does not arrive in time

### **Delays**

Digital circuits have delays! In addition to interconnections, all real electronic circuits introduces a delay with respect to input transitions with given rise and fall times. The delay caused by a logic cell is named propagation delay (typically it increases with chip temperature and supply voltage)

On the negative side, delays result in finite processing times and therefore set a limit on speed ...

... but on the positive side, delays are essential for the existence of **Sequential Logic** circuits (flip-flops → memories and state machines → processors)



The output should changes at the rising edge of the clock and remains unchanged for the entire clock period.

In real cases, switching from "1" to "0" or vice versa is not instantaneous but occurs with some delay because of the finite speed of electronic circuits that make the rising and falling times are not zero.

### Cause and Effect





Input B going high causes X to go low

Input A going low causes X to go high

#### Propagation Delay:

The time delay between a cause (an input changing) and its effect (an output changing), assuming output load capacitance of 30pF.

Example: 74AC00: Advanced CMOS 2-input NAND gate

min typ max 
$$A \uparrow \text{ to } X \downarrow (t_{PHL}) \qquad 1.5 \qquad 4.5 \qquad 6.5 \quad \text{ns}$$
 
$$A \downarrow \text{ to } X \uparrow (t_{PLH}) \qquad 1.5 \qquad 6.0 \qquad 8.0 \quad \text{ns}$$

 $t_{PHL}$  and  $t_{PLH}$  refer to the direction that the output changes: high-to-low or low-to-high.

### **D-Flip Flop**



#### Notation:

- input effect happens on the rising edge
- C1  $C \Rightarrow Clock input, 1 \Rightarrow This input <u>is</u> input number 1.$
- 1D ⇒ Data input,
   1 ⇒ This input <u>is controlled by</u> input number 1.

The meaning of a number depends on its position:

A number <u>after</u> a letter is used to identify a particular input. A number <u>before</u> a letter means that this input is controlled by one of the other inputs.

### **D-Flip Flop**



#### Cause and Effect:

- CLOCK↑ causes Q to change after a short delay.
   This is the <u>only</u> time Q ever changes.
- The value of D <u>just before</u> CLOCK↑ is the new Q.
- Propagation delay CLOCK↑ to Q is typically 1 ns.
- Propagation delay DATA to Q <u>does not make</u> <u>sense</u> since DATA changing does not cause Q to change.

### **D-Flip Flop**



Timing and delay parameters for flipflop is different from that with gates. Shown here is a D-FF that responses to a rising edge on the clock signal. A D-FF is like a camera, taking a "picture" from the scene (input is D). The clock input C1 is like the trigger on the camera — when pressed it samples the input and take a picture. The "cause" here is the rising edge of the CLOCK and the "effect" is the Q output sampling the D input, and keep the value until the next rising edge of the clock.

The delay here is from CLOCK rising edge to Q output changing. However, for the D-FF to work properly, there are two other timing parameters which are important: the **setup time** and the **hold time**. I will be talking about these in a later lecture.

### Asynchronous vs Synchronous Operation

Asynchronous operation serves for diverse specific processing that do not require using a clock (mismatches between delays can impair the results).

More reliable is when timing is controlled by a clock (synchronous operation). The period must be such as to accommodate the most time consuming processing section.

Often, the circuit includes sections where processing is performed in multiple clock periods.

### **Sequential Operation**

A sequential system relies on a sequence of actions, required to occur in the right order.

Sequential architectures can be synchronous and asynchronous.

Use of a clock to establish the update times of the feedback signals or no time control the circuit sends back outputs continuously as soon they change value.

Sequential circuits, both synchronous and asynchronous architectures enable higher level processing than combinational schemes.

With given inputs possible instability. It persists until a different input configuration takes the output out of unstable conditions.

### Combinatorial vs Sequential Operation

The task of combinational logics is just to relate signals at input and generate defined logic signals at output.



Input B going high causes X to go low

Input A going low causes X to go high

The output of combinational circuits depends only on input.

Sequential circuits produce output on the basis of both input and output.

For example, a memory circuit is essentially sequential, because its output depends on the input that occurred in the past. Instead, the addition of two inputs is combinational because the result just depends on changing inputs.



### Ripple Counter

example of a D-FF used in a ripple counter.



- Notice inverters on the CLOCK and DATA inputs
- Least significant bit of a number is always labelled 0

#### State Diagram

(not including transient states):



Propagation Delay: CLOCK $\Psi$  to Q2 = 3 x 1ns = 3ns

This counter is also known as an **asynchronous sequential circuit**. It is "**asynchronous**" because the output signals are NOT synchronised to a single clock signal (since there are many clock signals), and "**sequential**" because its current output value (or state) depends on previous output values in the sequence.

### Ripple Counter

example of a D-FF used in a ripple counter.



- Q0 value is first inverted (represented by the triangle) and then used as D input on the next clock cycle. The flipflop is triggered on the FALLING edge of CLOCK. Therefore the Q output "TOGGLES" on each active edge of the clock (i.e. falling edge). Q0 is therefore changing at half the rate of CLOCK, hence this flipflop acts as a divide-by-2 circuit.
- The Q0 signal is now used as clock input to the next D-FF. Hence Q1 is toggling at half the frequency of Q0. The circuit is effectively a binary counter.
- This is a simple finite state machine (FSM) because it has 8 states which cycles through in a sequence. FSM will be covered in some later lectures in details and it is a very important topic in digital designs.

We then use the Q0 output as the clock input the next stage etc. Note that because the 2<sup>nd</sup> stage only starts to work once the first stage is completed, the propagation of effects "ripples" through the circuit – hence we call this a "ripple counter".

- Notice inverters on the CLOCK and DATA inputs
- Least significant bit of a number is always labelled 0

#### State Diagram

(not including transient states):



### Ripple Counter

example of a D-FF used in a ripple counter.



- Notice inverters on the CLOCK and DATA inputs
- Least significant bit of a number is always labelled 0

#### State Diagram

(not including transient states):



Propagation Delay: CLOCK $\Psi$  to Q2 = 3 x 1ns = 3ns

The ripple counter is potentially slow. The delay between the active edge of the clock and the counter output giving the correct value is dependent on the number of flipflops in the circuit and therefore the size of the counter (i.e. how many stages).

### Synchronous Counter



All flipflops change state within a fraction of nanosecond of each other.

A far better approach is to use the flipflops TOGETHER as a group, and clock them using THE SAME CLOCK signal as shown here. The Logic Block is a combinatorial circuit which computes the next D value D2:0 from the current Q value Q2:0. (D has three bits D0, D1 and D2. We use the notation D2:0 to represent this.) The relationship between D and Q is simple: D2:0 = Q2:0 + 1.

### Synchronous Counter



All flipflops change state within a fraction of nanosecond of each other.

Since the three output bits Q2:0 change within a fraction of a nanosecond of each other, this circuit is: 1) faster than the ripple counter; 2) the "delay" is constant instead of dependent on the size of the counter.

### Synchronous Counter



All flipflops change state within a fraction of nanosecond of each other.

This circuit is known as a **synchronous sequential circuit** because its function is synchronous to a single clock signal. If you regard the Q2:0 output value as a state value, it follows a finite number of states in a defined sequence. Therefore it is also a form of **Finite State Machine**.

### **Additional Material**

## D-Latch





# D-Latch (2)



FF

